#include <iostream>
#include <unordered_set>
using namespace std;
const int N=1e5+10;

unordered_set<int> has[N];
int main()
{
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		int t;
		scanf("%d",&t);
		while(t--)
		{
			int num;
			scanf("%d",&num);
			has[i].insert(num);
		}
	}
	int q;
	cin>>q;
	while(q--)
	{
		int x,y;
		cin>>x>>y;
		int ret=0;
		for(int i=1;i<=n;i++)
		{
			if(has[i].count(x) && has[i].count(y))
			{
				ret++;
			}
		}
		cout<<ret<<endl;
	}
	return 0;
}
